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Abstract. We consider the following NP-hard problem: in a weighted graph, find a 
minimum cost set of vertices whose removal leaves a graph in which no two cycles share 
an edge. We obtain a constant-factor approximation algorithm, based on the primal- 
dual method. Moreover, we show that the integrality gap of the natural LP relaxation 
of the problem is O(logn), where n denotes the number of vertices in the graph. 
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1. Introduction 

Graphs in this paper are finite, undirected, and may contain parallel edges but no 
loops. We study the following combinatorial optimization problem: given a vertex- 
weighted graph, remove a minimum cost subset of vertices so that all the cycles in the 
resulting graph are edge-disjoint. We call this problem the diamond hitting set problem, 
because it is equivalent to covering all subgraphs which are diamonds with a minimum 
cost subset of vertices, where a diamond is any subdivision of the graph consisting of 
three parallel edges. 

The diamond hitting set problem can be thought of as a generalization of the vertex 
cover and feedback vertex set problems: Suppose you wish to remove a minimum cost 
subset of vertices so that the resulting graph has no pair of vertices linked by k internally 
disjoint paths. Then, for k = 1 and k = 2, this is respectively the vertex cover problem 
and feedback vertex set problem, while for k = 3 this corresponds to the diamond hitting 
set problem. 

It is well-known that both the vertex cover and feedback vertex set problems admit 
constant-factor approximation algorithm^] Hence, it is natural to ask whether the same 
is true for the diamond hitting set problem. The main contribution of this paper is a 
positive answer to this question. 
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1.1. Background and Related Work. Although there exists a simple 2-approximation 
algorithm for the vertex cover problem, there is strong evidence that approximating 
the problem with a factor of 2 — e might be hard, for every e > [11]. It should be 
noted that the feedback vertex set and diamond hitting set problems are at least as 
hard to approximate as the vertex cover problem, in the sense that the existence of 
a p-approximation algorithm for one of these two problems implies the existence of a 
p- approximation algorithm for the vertex cover problem, where p is a constant. 

Concerning the feedback vertex set problem, the first approximation algorithm is due 
to Bar- Yehuda, Geiger, Naor, and Roth [2] and its approximation factor is O(logn). 
Later, 2-approximation algorithms have been proposed by Bafna, Berman, and Fujito [I], 
and Becker and Geiger [3]. Chudak, Goemans, Hochbaum and Williamson [5] showed 
that these algorithms can be seen as deriving from the primal-dual method (see for 
instance |14| [H]). Starting with an integer programming formulation of the problem, 
these algorithms simultaneously construct a feasible integral solution and a feasible dual 
solution of the linear programming relaxation, such that the values of these two solutions 
are within a constant factor of each other. 

These algorithms also lead to a characterization of the integrality gapj^] of two different 
integer programming formulations of the problem, as we now explain. Let C(G) denote 
the collection of all the cycles C of G. A natural integer programming formulation for 
the feedback vertex set problem is as follows: 

Min c v x v 

v£V{G) 

(1) s.t. x v > 1 VC G C{G) 

ueV(C) 

x v e{0,l} VveV(G). 

(Throughout, c v denotes the (non-negative) cost of vertex v.) The algorithm of Bar- 
Yehuda et al. [2] implies that the integrality gap of this integer program is O(logn). 
Later, Even, Naor, Schieber, and Zosin [7j proved that its integrality gap is also O(logrt). 

A better formulation has been introduced by Chudak et al. [S]. For S C V(G), denote 
by E(S) the set of the edges of G having both ends in S, by G[S] the subgraph of G 
induced by S, and by ds(v) the degree of v in G[S]. Then, the following is a formulation 
for the feedback vertex set problem: 

Min c v x v 

ueV(G) 

(2) s.t. J2(d s (v) - l)x v ^ \E(S)\-\S\ + 1 VSCV(G):E(S)^0 

ves 

^£{0,1} WeV(G). 

2 The integrality gap of an integer programming formulation is the worst-case ratio between the opti- 
mum value of the integer program and the optimum value of its linear relaxation. 
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Chudak et al. [5 J showed that the integrality gap of this integer program asymptotically 
equals 2. Constraints ^ derive from the simple observation that the removal of a 
feedback vertex set X from G generates a forest having at most \G\ — \X\ — 1 edges. 
Notice that the covering inequalities ([I]) are implied by Q. 



1.2. Contribution and Key Ideas. First, we obtain a 0(log n)-approximation algo- 
rithm for the diamond hitting set problem, leading to a proof that the integrality gap of 
the natural LP formulation is G(logra). Then, we develop a 9-approximation algorithm. 
Both the O(logn)- and 9-approximation algorithm are based on the primal-dual method. 

Our first key idea is contained in the following observation: every simple graph of 
order n and minimum degree at least 3 contains a 0(logn)-size diamond. This directly 
yields a 0(log n)-approximation algorithm for the diamond hitting set problem, in the 
unweighted case. However, the weighted case requires more work. 

Our second key idea is to generalize constraints ^ by introducing 'sparsity inequali- 
ties', that enable us to derive a constant-factor approximation algorithm for the diamond 
hitting set problem: First, by using reduction operations, we ensure that every vertex 
of G has at least three neighbors. Then, if G contains a diamond with at most 9 edges, 
we raise the dual variable of the corresponding covering constraint. Otherwise, no such 
small diamond exists in G, and we can use this information to select the right sparsity 
inequality, and raise its dual variable. This inequality would not be valid in case G 
contained a small diamond. 

The way we use the non-existence of small diamonds is perhaps best explained via 
an analogy with planar graphs: An n-vertex planar simple graph G has at most 3n — 6 
edges. However, if we know that G has no small cycle, then this upper bound can be 
much strengthened. (For instance, if G is triangle-free then G has at most In — 4 edges.) 

We remark that this kind of local/global trade-off did not appear in the work of Chudak 
et al. [5] on the feedback vertex set problem, because the cycle covering inequalities are 
implied by their more general inequalities. In our case, the covering inequalities and 
the sparsity inequalities form two incomparable classes of inequalities, and examples 
show that the sparsity inequalities alone are not enough to derive a constant-factor 
approximation algorithm. 

The paper is organized as follows. Preliminaries are given in Section [2j Then, in 
Section |3j we define some reduction operations that allow us to obtain graphs having 
some desirable properties. Next, in Section |4j we deal with the unweighted version of 
the diamond hitting set problem and provide a simple 0(logn)-approximation algorithm. 
In Section [5j we turn to the weighted version of the problem. We present a O(logn)- 
approximation algorithm and we prove that the integrality gap of the natural formulation 
of the problem is O(logra). Finally, in Section [6j we introduce the sparsity inequalities, 
analyze their strength and obtain a 9-approximation algorithm. 
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2. Preliminaries 

We refer the reader to Diestel [6] for undefined terms and notations concerning graphs. 
A cactus is a connected graph where each edge belongs to at most one cycle. Equivalently, 
a connected graph is a cactus if and only if each of its blocks is isomorphic to either K\ , 
K2, or a cycle. Thus, a connected graph is a cactus if and only if it does not contain 
a diamond as a subgraph. A graph without diamonds is called a forest of cacti (see 
Figure [T] for an illustration). 




Figure 1. A forest of cacti. 

A diamond hitting set, or simply hitting set, of a graph is a subset of vertices that hits 
every diamond of the graph. A minimum hitting set of a weighted graph is a hitting set 
of minimum total cost, and its cost is denoted by OPT. 

Let T>(G) denote the collection of all diamonds contained in G. From the standard 
IP formulation for a covering problem, we obtain the following LP relaxation for the 
diamond hitting set problem: 

Min °v %v 

veV(G) 

(3) s.t. x v > 1 VD G V{G) 

veV(D) 

x v ^ Vv G V(G). 
We call inequalities ^ diamond inequalities. 

3. Reductions 

In this section, we define two reduction operations on graphs: First, we define the 
'shaving' of an arbitrary graph, and then introduce a 'bond reduction' operation for 
shaved graphs. 

The aim of these two operations is to modify a given graph so that the following useful 
property holds: each vertex either has at least three distinct neighbors, or is incident to 
at least three parallel edges. 

3.1. Shaving a graph. Let G be a graph. Every block of G is either isomorphic to 
K\, K%, a cycle, or contains a diamond. Mark every vertex of G that is included in a 
block containing a diamond. The shaving of G is the graph obtained by removing every 
unmarked vertex from G. A graph is shaved if all its vertices belong to a block containing 
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a diamond. Observe that, in particular, every endblocl^ of a shaved graph contains a 
diamond. See Figure [2] for an illustration. 





(b) 



Figure 2. (a) A graph G. (b) The graph obtained by shaving G. 



3.2. Reducing a bond. A bond of a graph G is a connected subgraph Q C G equipped 
with two distinguished vertices v,w (called ends) satisfying the following requirements: 

• Q is a cactus with at least two blocks; 

• the block-graph of Q is a path; 

• v and w belong to distinct endblocks of Q; 

• v and w are not adjacent in Q; 

• Q — {v, w} is a non-empty component of G — {v, w}, and 

• Q contains all the edges in G between {v, w} and V(Q) — {v, w}. 

Observe that Q is "almost" an induced subgraph of G, since Q includes every edge 
of G between vertices of Q, except those between v and w (if any). The vertices in 
V(Q) — {v, w} are said to be the internal vertices of Q. The bond Q is simple if Q is 
isomorphic to a path, double otherwise. 

Let G be a shaved graph. A vertex u of G is reducible if u has exactly two neighbors 
in G, and there are at most two parallel edges connecting u to each of its neighbors. The 
bond reduction operation is defined as follows. Let u be a reducible vertex and let Q u 
be an inclusion- wise maximal bond of G containing u, with ends v and w. (Observe that 
such a bond exists by our hypothesis on u; moreover, it might not be unique.) Then, 
remove from G every internal vertex of Q u , and add one or two edges between v and w, 
depending on whether Q u is simple or double. In the latter case, the two new parallel 
edges are said to be twins. See Figure [3] for an illustration of the operation. Observe 
that the resulting graph is also a shaved graph. 

A crucial property of the bond reduction operation is that, when applying it itera- 
tively, we never include in the bond to be reduced any edge coming from previous bond 
reductions. This is proved in the following lemma. 



We recall that the block-graph of G has the blocks of G and the cutvertices of G as vertices, a block 
and a cutvertex are adjacent if the former contains the latter. This graph is always acyclic. An endblock 
of G is a vertex of the block-graph with degree at most one. 
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(a) 



(b) 



(c) 



Figure 3. (a) A shaved graph G with two maximal bonds (in grey), 
(b) Reduction of the first bond, (c) Reduction of the second bond. The 
graph is now reduced. 

Lemma 3.1. Let Gi be a graph obtained from G after applying i bond reductions. Let 
Ei := E(G{) — E(G). Let v be a reducible vertex of Gi. Let Q v be a maximal bond of Gi 
containing v. Then, E(Q V ) n Ei = 0. 

Proof. Arguing by contradiction, assume E{Q V ) n E% ^ 0. Let j be the maximum index 
such that j < i and Q v contains an edge e produced during the j'th bond reduction. Let 
w be the vertex that has been reduced at iteration j, and denote by Q w the corresponding 
bond. Note that, if Q w is double, then e and its twin edge e' are both included in Q v 
(by construction). Now, replacing e (and e' if it exists) by Q w in Q v produces a bond 
of Gj that includes w and is strictly larger than Q w . This contradicts the maximality of 



A reduced graph G of G is any graph obtained from G by iteratively applying a bond 
reduction, as long as there is a reducible vertex (see Figure [3]) . We remark that there is 
not necessarily a unique reduced graph of G (consider for instance K% where two edges 
are doubled). 

As mentioned earlier, every reduced graph has the following desirable property: every 
vertex either has at least three distinct neighbors or is incident to at least three parallel 
edges. 

4. A 0(logn)-APPROXIMATION ALGORITHM IN THE UNWEIGHTED CASE 

In this section, we deal with the unweighted version of the diamond hitting set prob- 
lem. We first show that every reduced graph with n vertices contains a diamond of size 
O(logn), and then provide a 0(logn)-approximation algorithm. 

4.1. Small diamonds in reduced graphs. As a first step, we show that every simple 
graph with minimum degree at least 3 contains a diamond of size O(logn). 

Lemma 4.1. Every simple n-vertex graph with minimum degree at least 3 contains a 
diamond of size at most 61og3/ 2 ?i< + 8. Moreover, such a diamond can be found in 
polynomial time. 



Q 



□ 
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Proof. Let G be a simple graph with n vertices and minimum degree at least 3, and let 
u be an arbitrary vertex of G. For d 0, let Nd be the set of vertices at distance d from 
u; also, let be a spanning tree of the graph induced by iVo U • • • U Nd such that, for 
every vertex v of Td, the distance from u to v in Td is the same as in G. (Such a tree 
can be obtained by breadth-first search, for instance.) Notice that the set of leaves of Td 
is exactly Nd- 

For d ^ 1, color in white the vertices in Nd that have exactly one neighbor in Nd—iUNd] 
in black those that have exactly two, and in red those that have at least three of them. 

Claim 4.2. Let d ^ 1. If Nd contains a red vertex, then G has a diamond of size at 
most 3d + 2. The same is true if Nd contains a black vertex in Nd with a black neighbor 
in Nd-i, or two black vertices in Nd that are not adjacent and have a common neighbor 
in Nd-\- 

Proof. We only consider the case of a red vertex, the proof of the two other cases is 
similar and left to the reader. Let v G Nd be a red vertex. Let v\ be the unique neighbor 
of v in the tree Td- (Thus, v% G Nd—i-) Let v 2 ,V3 be two neighbors of v in Nd-\ U Nd 
that are distinct from v% . Let C 2 and C3 be the unique cycles in Td + vv 2 and Td + W3 , 
respectively. These two cycles are distinct and share the edge vv\; hence, C2UC3 contains 
a diamond D. Let Pj (i = 1, 2, 3) be the u-Vi path in Td, augmented with the edge W{. 
Observe that C 2 U C 3 C P x U P 2 U P 3 . Therefore, the size of D is 

H-DIK HC2UC3II ^ ||Pi|| + ||P 2 || + ||P3|| < d+(d + l) + (d + l) = 3d + 2. 

□ 

Claim 4.3. Lei d ^ 2. 7/G /ios no diamond of size at most 3d + 2, i/ien |A^| ^ 11^-21- 

Proof. Assume that G has no diamond of size at most 3d + 2. The claim is easily seen 
to hold if d = 2, so we assume d 3. 

For i G {1, . . . ,d}, let it;, and 6j be the number of white and black vertices in iVj, 



respectively. By Claim 4.2, there is no red vertex in Nf, thus, |A^| = Wi + bi. Let pi 
and % be the number of black vertices in Ni having one and two neighbors in A^_i, 
respectively; so, bi = Pi + q- L . 

Now, fix i G {2, . . . , d}. (Thus, vertices in both Ni and iVj_i are colored in black and 
white.) Since G has minimum degree at least 3, every vertex in N^i has at least one 



neighbor in Ni. By Claim 4.2, every black vertex in iVj_i has at least one white neighbor 
in Ni, showing 

(4) Wi > 

The number of edges between N-i and N in G is exactly Wi + pi + 2qi =: mi. On the 
other hand, we also have rrtj 2wj_i + since every white vertex in A^_i has at 
least two neighbors in Ni and every black vertex in A^_i has at least one neighbor in N{. 
Hence, 

(5) Wi +pi + 2qi ^ 2wi-x + 6j_i. 
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By Claim 4.2 if a white vertex in A^_i is adjacent to two black vertices in Ni, then 
the latter vertices are adjacent. Also, black vertices in Ni can only be adjacent to white 



vertices in iVj_i, again by Claim 4.2 These two observations imply 

(6) \ Wi - 1 ^ Qi ' 

Using Eq. ([5} and @, we obtain 

3 

\Ni\ = Wi + Pi + qi ^ 2u7j_i + 6j_i - qi ^ + 



It follows 



2 



3 

\N d \ ^ -w d -i + 

= |JVd-i| + o^- 1 

X 3 L 1 

^ 2 Wd " 2 + d ~ 2 + 2 Uj ' i_1 

= |iVd_ 2 | + 7^-2 + \ W d-l 

^ l-ATd— a| + 2 Wd - 2 + \ hd - 2 



\\N d -2\ 



as claimed. (The last inequality follows from Eq. Q.) □ 



4.3 



Now, we may prove Lemma 4.1 Let d be the largest even integer such that G has 
no diamond of size at most 3d + 2. If d ^ 2, then G has a diamond with size at most 
3(d + 2) + 2 ^ 14 ^ 6 log 3/2 n + 8 (since n > 4). Thus, assume d ^ 4. By Claim 

d 

n ^ ^ |JVi| 

> \N \ + \N 2 \ + ... + |iV d _ 2 | + \N d \ 
3 (3\ d/2 - 1 /3^ d/2 



d/2 



that is, 



d < 21og 3/2 n. 

Therefore, G has a diamond of size at most 3(d + 2) + 2 ^ 6 log 3 / 2 n + 8. 

To conclude, we note that the above proof is easily turned into a polynomial-time 
algorithm finding the desired diamond. □ 

The same result holds for reduced graphs: 

Lemma 4.4. Every reduced graph G contains a diamond of size at most 61og 3 / 2 \G\ +8. 
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Proof. We can assume that any two adjacent vertices of G are adjacent through at most 
2 parallel edges, since otherwise there is a diamond with three edges and the statement 
trivially holds. Thus, each vertex of G has at least three distinct neighbors. Let G 1 be 
the subgraph of G obtained by replacing every double edge by a simple edge. Clearly, 



G' is simple and has minimum degree at least 3. Therefore, by Lemma 4.1, G' has a 
diamond (which can be found in polynomial time) of size at most 61og 3 / 2 \G'\ +8, thus 
at most 61og 3 / 2 |G| +8. The result follows. □ 

4.2. The algorithm. Our algorithm for the diamond hitting set problem on unweighted 
graphs is described in Algorithm [TJ 

Algorithm 1 A 0(logn)-approximation algorithm for unweighted graphs. 

• X <r- 

• While X is not a hitting set of G, repeat the following steps: 

— Compute a reduced graph G of G — X 

— Find a diamond D in G of size at most 61og 3 / 2 \G\ + 8 (using Lemma 4.4) 

— Include in X all vertices of D 



The algorithm relies on the simple fact that every hitting set of a reduced graph G of a 
graph G is also a hitting set of G itself. The set of diamonds computed by the algorithm 
yields a collection T> of pairwise vertex-disjoint diamonds in G. In particular, the size of a 
minimum hitting set is at least \D\. For each diamond in T>, at most 61og 3 / 2 n + 8 vertices 
were added to the hitting set X. Hence, the approximation factor of the algorithm is 
O(logn). 



5. A 0(logn)-APPROXIMATION ALGORITHM 

The present section is devoted to a 0(log n)-approximation algorithm for the diamond 
hitting set problem in the weighted case, which is based on the primal-dual method. We 
start by defining, in Section 5.1, the actual LP relaxation of the problem used by the 
algorithm, together with its dual. Then, in Section |5.2[ we describe the approximation 



algorithm and, in Section 5.3, we prove that it provides a 0(log n)-approximation for the 



diamond hitting set problem. Finally, in Section [5. 4[ we show that the integrality gap of 
the natural LP relaxation for the problem (see ([3]), page[4j) is 0(logn). This last result 
is obtained using expander graphs with large girth. 



5.1. The working LP and its dual. Our approximation algorithm is based on the nat- 
ural LP relaxation for the diamond hitting set problem, given on page[4j To simplify the 
presentation, we do not directly resort to that LP relaxation but to a possibly weaker 
relaxation that is constructed during the execution of the algorithm, that we call the 
working LP. At each iteration, an inequality is added to the working LP. These inequali- 
ties, that we name blended diamond inequalities, are all implied by diamond inequalities 
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([3]). The final working LP reads: 

(LP) Min ^2 c v x v 
veV{G) 

s.t. ^2 a i:V x v ^f3i Mi G {1, . . . , k} 

v£V(G) 

x v ^0 Vug V(G), 

where k is the total number of iterations of the algorithm. The dual of (LP) is: 

k 

(D) Max ^/3 iyi 



s.t. ^ai^yi ^ c v Mv G V(G) 

i=l 

Mi G {1, . . . ,k}. 

The algorithm is based on the primal-dual method. It maintains a boolean primal 
solution x and a feasible dual solution y. Initially, all variables are set to 0. Then the 
algorithm enters its main loop, that ends when x satisfies all diamond inequalities. At 
the zth iteration, a violated inequality Y^veV ai , v Xv ^ A ^ s & dded to the working LP 
and the corresponding dual variable yi is increased. In order to preserve the feasibility 
of the dual solution, we stop increasing yi whenever some dual inequality becomes tight. 
That is, we stop increasing when J2)=i a i,v Vj = c v for some vertex v, that is said to be 
tight. Furthermore, we also stop increasing yi in case a 'collision' occurs (see Section 



5.2.4). All tight vertices v (if any) are then added to the primal solution. That is, the 
corresponding variables x v are increased from to 1. The current iteration then ends 
and we check whether x satisfies all diamond inequalities. If so, then we exit the loop, 
perform a reverse delete step, and output the current primal solution. 

The precise way the violated blended diamond inequality is chosen is defined in Sections 



5.2.1 and 5.2.3 It depends among other things on the residual cost (or slack) of the 
vertices. The residual cost of vertex v at the ith iteration is the number c v — Y^j=\ a j,v Vj- 
Note that the residual cost of a vertex is always nonnegative, and zero if and only if the 
vertex is tight. 

5.2. The algorithm. A formal definition of the algorithm is given in Algorithm [2] All 
the steps are explicit, except those labeled *, which will be specified later. 

Above, £ is a collection of triples (T, B, {v, w}) used to guide the choice of subgraph 



S, where T and B are internally disjoint v-w paths (see Section 5.2.2). 

We remark that the set X naturally corresponds to a primal solution x, obtained by 
setting x v to 1 if v G X, to otherwise, for every v G V(G). This vector x satisfies the 
diamond inequalities ^ exactly when we exit the while loop of the algorithm, that is, 
when X becomes a hitting set. 

The reverse delete step consists in considering the vertices of X in the reverse order 
in which they were added to X and deleting those vertices v such that X — {v} is still a 
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5.2.1 



Algorithm 2 A 0(logn)-approximation algorithm for weighted graphs. 

• X <r- 0; y^O; i «- 0; 

• While X is not a hitting set of G = (V, E), repeat the following steps: 

— i <- i + 1 

— Let i? be the graph obtained by shaving G — X 

— Find a reduced graph H of H 

— Find a diamond D in iT of size 61og 3 / 2 + 8 (using Lemma 

★ Find an induced subgraph S of H, based on D (see Section 

★ If S is not consistent with £, modify S (see Section 5.2.2) 

★ Compute a violated blended diamond inequality J2vev ai , v Xv ^ Ph 

based on S, £ and the residual costs; add it to (LP) (see Section 5.2.3) 
-k Increase yi until some vertex becomes tight, or a collision occurs 

(see Section 5.2.4) 

•k Update £ (see Section 5.2.5) 

★ Add all tight vertices u to 1, in a certain order (see Section 5.2.6) 
•k Re- update £ (see Section 5.2.7) 

• k i 

• Perform a reverse delete step on X 



hitting set. Observe that, because of this step, the hitting set X output by the algorithm 
is inclusion-wise minimal. 



The remainder of this section is organized as follows. In Section 5.2.1 we define the 



'support graph' S of the inequalities and then explain, in Section [5. 2. 2[ how to modify it 
when it is not consistent with £. After that, we define the blended diamond inequalities 



in Section 5.2.3, we define collisions and explain how to take care of them in Section 
|5.2.4[ we specify the insertion order of vertices in the solution in Section 5.2.6, and we 



explain the way list £ is updated in Sections 5.2.5 and 5.2.7 



5.2.1. The support graph of the inequalities. First, we need some definitions. Let H be 
a shaved graph and let if be a reduced graph of H (as defined in Section I3J). Vertices in 
V{H) and V{H)—V{H) are called branch vertices and internal vertices of H, respectively. 

We will consider graphs that are equipped with a collection of specific subgraphs, 
called 'pieces', which have a structure similar to that of bonds. The first kind of such 
graphs are simply diamonds: Consider a diamond D, and replace each edge vw G E{D) 
with a path between v and w. Each such path is a piece of the resulting diamond; the 
vertices v,w are the ends of the piece, the others are the internal vertices of the piece. 

A second kind of graph equipped with pieces is a necklace, defined as any graph 
obtained as follows. First, choose a cycle C (cycles consisting of two parallel edges are 
allowed). Then, select a non-empty subset Z of edges of C. Next, replace each edge 
vw £ E(C) — Z of C with a path between v and w. Finally, replace each edge vw £ Z 
either by two internally disjoint v-w paths, or by a cactus whose block-graph is a path, 
in such a way that v and w lie in distinct endblocks of the cactus and in no other block. 
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In both cases, the subgraph by which an edge of C has been replaced is called a piece of 
the necklace; ends and internal vertices of the piece are defined as expected. See Figure [4] 
for an illustration. 

A piece Q of a diamond or necklace is simple if Q is isomorphic to a path, double 
otherwise. Let us point out that, while pieces and bonds look very similar at first sight, 
there are some differences between the two notions. (Notice for instance that a piece of 
a necklace could consist of a single edge or a cycle.) 

A diamond or necklace S together with its pieces is rooted in H if 

• S is an induced subgraph of H; 

• every end of a piece of S is a branch vertex of H; 

• every internal vertex of a piece of S is an internal vertex of H, and 

• there is no edge in H between an internal vertex of a piece of S and a vertex in 
V(H)-V(S). 

(Observe that this definition also depends on H, since the latter graph determines which 
vertices of H are branch vertices.) 




Figure 4. A cycle C, where edges in Z are thicker (left) and a necklace 
built from C (right). 



Lemma 5.1. Let H be a shaved graph. Let H be a reduced graph of H. Then, given a 
diamond D C H , one can find in polynomial time a subgraph S of H such that one of 
the following conditions is satisfied: 

(i) S is a diamond rooted in H, with at most \ \D\\ pieces; 

(ii) S is a necklace rooted in H, with at most \ \D\\ pieces; 

(Hi) S consists of two vertices with at least four parallel edges between them; 
(iv) S is isomorphic to K4. 

Proof First, we associate to each edge of H a corresponding primitive subgraph in H, 
defined as follows. Consider an edge e G E(H). If e was already present in H, then its 
primitive subgraph is the edge itself and its two ends. Otherwise, the primitive subgraph 
of e is the bond whose reduction produced e. In particular, if e has a twin edge e', then 
the primitive subgraphs of e and e' coincide. The primitive subgraph J of a subgraph 
J C H is defined simply as the union of the primitive subgraphs of every edge in E(J). 
Note that primitive subgraphs are well-defined, thanks to Lemma 3.1 Also, notice that 
the primitive subgraph of a subgraph of H is not defined per se, but with respect to the 
bond reductions which produced H from H . 
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Let K denote the subgraph of H induced by V(D). Consider an induced subgraph K' 
of K that contains a diamond and is vertex-minimal with that property, that is, K' — v 
is a forest of cacti for every v E V(K'). Let n be the maximum number of parallel edges 
between pairs of adjacent vertices in K' . 

First, suppose \i = 1. As the reader will easily check, the minimality of K' implies 
that either K' is a simple diamond, or K' is isomorphic to K±. 

In the first case (K' is a simple diamond) , the primitive subgraph S of K' in H can be 
seen as a diamond with \ \K'\ \ pieces. It follows from the definition of primitive subgraphs 
and the fact that H is shaved, that S is rooted in H. Also, we trivially have | \K'\ | ^ | \D\ | ; 
thus, S has at most \\D\\ pieces. Hence, S satisfies (JTJ) - 

In the second case (K 1 ~ K4), we may assume that the primitive subgraph of K' is 
not isomorphic to K' (otherwise, ( Jiv| ) holds). Then, there is an edge e E E(K') such that 
the primitive subgraph of e is a path of length at least 2. Let then S be the primitive 
subgraph of K' — e. The subgraph S is induced in H and is a diamond with \ \K' — e|| 
pieces. Since, similarly as before, S is rooted in H and \ \K' — e\\ ^ it follows that 

S satisfies ([I]). 

Next, assume /i = 2. Let v,w be two vertices of if that are connected by two parallel 
edges ei,e2 in K'. Let P be a shortest v-w path in the graph K' — {ei,e2}. (Observe 
that such a path exists, since K' contains a spanning diamond.) Then, all vertices of K' 
are included in P. Thus, K' is a simple cycle with some (and at least one) of its edges 
replaced by pairs of parallel edges. Let S be the primitive subgraph of K' in H. Then, S 
is a necklace rooted in H and has at most \K'\ ^ \\K'\\ ^ ||L>|| pieces. Hence, S satisfies 

Now, suppose fi ^ 3. Then, if' consists of two vertices v and w connected by \x parallel 
edges. If H contains a pair of vertices with at least four parallel edges between them, 



then (iii) holds for the obvious choice of S, and we are done. Thus, assume there are at 
most three edges between any two vertices in H. 

Let S be the primitive subgraph of K' . If K' contains no pair of twin edges, then S 
consists of at most three edges between v and w and at least /i — 3 longer paths between 
v and w. By removing vertices from S if necessary, we can ensure that S satisfies ([!]). 
Otherwise, K' contains at least one pair of twin edges. In this case, by removing vertices 
from S if necessary, we can ensure that S satisfies , or ([!]) if S' has three parallel edges 
between v and w 

Finally, we note that the above proof can be turned without difficulty into a 
polynomial-time algorithm computing S, thus concluding the proof. □ 

We say that an induced subgraph S C H is of type 1 (type 2, 3, 4, resp.) if it satisfies 
condition (i) (condition (n), (iii), (iv), resp.) of the above lemma. 



5.2.2. Modifying the graph S. Consider some iteration i of the algorithm, the correspond- 
ing shaved graph H and the induced subgraph S of H produced at that iteration. Here, 
we explain how to modify S when it is not consistent with C. If S is of type 3 or 4, there 
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is no need to modify it. Hence, we assume that S is of type 1 or 2 for the rest of this 
section. First, we need to introduce more terminology. 

Consider a piece Q of S containing a cycle C. Then C is a block of Q. A vertex v of C 
is said to be an end of the cycle C if v is an end of the piece Q or v belongs to a block of 
Q distinct from C. Observe that C has always two distinct ends. The cycle C has also 
two handles, defined as the two v-w paths in C, where v and w are the two ends of C. 
A handle is trivial if it has no internal vertex, non-trivial otherwise. 

The two handles of C are labelled top and bottom as follows. Suppose C has two 
non-trivial handles, and compute the minimum residual cost of an internal vertex in each 
handle. If this minimum is achieved in exactly one handle, then this handle is the top 
handle. If, on the other hand, the minimum is achieved in both, then the tie is broken 
arbitrarily, unless the cycle C was considered in a previous iteration. In this case, we 
ensure that the tie is always broken in the same way (actually, we can use the list C to 
determine this, see below). Now, if C has only one non-trivial handle, then it is defined 
to be the top handle. Finally, if both handles of C are trivial (that is, C is a cycle of 
length 2), then one of them is chosen arbitrarily and called the top handle. In each of 
these three cases, the bottom handle is the other handle, as expected. 

Now, we may give a precise definition of C: it is a collection of triples (T,B,{v,w}) 
satisfying all of the following conditions: 

• v,w are two distinct vertices of H, 

• T and B are two v—w paths in H that are internally disjoint, 

• T has at least one internal vertex, 

• internal vertices of T and B have exactly two neighbors in H. 
Moreover, we require that 

• for every two distinct triples (T, B, {v , w}), (T' , B' ,{v' ,w'}) in C, no two of the 
four paths T,T' , B, B' have an internal vertex in common. 

The graph S is consistent with a triple (T, B, {v, w}) in C if any of the following 
conditions is satisfied: 

(CI) S contains no internal vertex of any of the paths T, B, 

(C2) S contains T in one of its simple pieces and no internal vertex of B, 

(C3) S is of type 1 and contains the cycle TUB, 

(C4) S is of type 2 and contains T U B in one of its (double) pieces. 

We say that S is consistent with the collection C if S is consistent with every triple in C. 

Next, we explain how to modify S if it is not consistent with C Roughly speaking, the 
purpose of this step is to ensure that no vertex in a bottom handle becomes tight before 
some vertex in the corresponding top handle becomes tight. This property is crucial for 
our analysis of the algorithm. 

We iteratively modify S, until it becomes consistent with £: Let (T, B,{v,w}) G £ 
be such that S is not consistent with (T, B, {v, w}). (Recall that S is of type 1 or 2, by 
assumption.) Because (CJT|) is not satisfied, S contains an internal vertex of T or B. 
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Claim 5.2. If P is any path in {T, B} such that one of its internal vertices is contained 
in S, then the whole path P is contained in S. 

Proof. Let u be an internal vertex of P contained in S. Because u is an internal vertex 
of P, it has exactly two neighbors in H. Because u is a vertex of S and S is a diamond 
or a necklace, u has at least two neighbors in S. Thus, the two neighbors of u in H are 
in S. By repeating this argument, it follows that the whole path P is contained in S. □ 

By what precedes, we may assume that some path P G {T, B} has at least one internal 



vertex in S. By Claim 5.2 P is entirely contained in S. Because every end of a piece of 
S is a branch vertex, all vertices of P are in the same piece of S, say Q. Let P' denote 
the other path in {T, B}. 

Claim 5.3. Assume that the cycle P U P' = T U B is entirely contained in S. Then, S 
is a necklace with two pieces, one piece is a cycle with ends v and w, and the other piece 
is either a v^w path or also a cycle with ends v and w. 

Proof. Because S is not consistent with (T, B, {v, w}), neither (C[3]) nor (CQ is satisfied. 
It follows that S is a necklace, and the v-w paths P and P' are contained in different 
pieces of S. In particular, S has two distinct pieces sharing two distinct vertices, namely 
v and w. This implies that S has exactly two pieces, and v and w are the ends of both 
pieces. One of the pieces contains P (namely, Q) and the other contains P' . The rest of 
the claim follows easily. □ 

Case 1. No internal vertex of P' is contained in S. 

First, assume that the path P 1 has no internal vertex. Then, the whole cycle P U P' 



is contained in S because S is induced in H. By Claim 5.3, we can transform S into a 
diamond, by deleting a (possibly empty) subset of the vertices of S. 

Second, assume that P' has at least one internal vertex. Because v and w are vertices 
of S that have at least one neighbor outside S, they are branch vertices. Thus, v and w 
are the ends of the piece Q. 

If Q is simple, then we have P = B and P' = T because otherwise S would be 
consistent with (T, B, {v, w}). In this case, we redefine S as the subgraph of H induced 
by (V(5) - V(B)) U V(T). (Thus, we "replace" B with T in S.) 

If Q is double, then Q is a cycle with ends v and w, and S is a necklace. Then, we 
transform S into a diamond, by redefining S as Q U P'. 

Case 2. Some internal vertex of P' is contained in S. 



By Claim 5.2 it follows that all vertices of P' are contained in S. Hence, S contains 



the whole cycle P U P' . Again, by Claim 5.3, we can transform S into a diamond, by 
deleting a subset of the vertices of S. 

In all the cases above, we either transform S into a diamond, or make S consistent 
with (T, B, {v, w}) without creating a new inconsistency. It follows that the modification 
process is finite, and produces a new induced subgraph S still satisfying the requirements 
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of Lemma 5.1 that is moreover consistent with all triples in C. Clearly, modifying S can 



be done in polynomial time. 

5.2.3. Computing the inequality. Let C be a cycle contained in a piece Q of S. If at least 
one handle of C is non-trivial, then we denote by t{C) (resp. 6(C)) the minimum residual 
cost of an internal vertex in the top handle (resp. bottom handle) of C. The convention 
is that 6(C) = oo if the bottom handle is trivial. It will be convenient to say that a 
vertex belongs to a handle if it is an internal vertex of that handle. 

To the graph S we associate a unique blended diamond inequality of the form 

(7) ^2 a i>v x v > 1, 

veV{G) 

whose support is contained in the vertex set of S. For convenience, we call S the support 
grapij^jof the inequality. If S is of type 1, 3, or 4, we let 

f 1 if u G V(S), 
Hv ~ \ if v e V(G) - V(S). 

If S is of type 2, we choose a cycle of S and declare it to be special, as follows: If there is 
a cycle C in a piece of S such that t(C) = 6(C), then we select such a cycle. Otherwise, 
we select an arbitrary cycle contained in a piece of S. Then, we let 

1 if v € V(S) and v belongs to no handle, 

if v belongs to the top handle of a non-special cycle C and t(C) < 6(C), 

1 if v belongs to the bottom handle of a non-special cycle C and t(C) < 6(C), 
| if v belongs to a handle of a non-special cycle C and t{C) = 6(C), 
1 if v belongs to a handle of the special cycle, 
i£veV(G)-V(S). 

Lemma 5.4. Every blended diamond inequality ^ is implied by the diamond and non- 
negativity inequalities. 

Proof. If S is of type 1, 3, or 4, Inequality ^ is a diamond inequality. Otherwise, ^ is 
easily seen to be a convex combination of two diamond inequalities. □ 

5.2.4. Taking care of collisions. When increasing the variable the residual cost c v — 
Y^j=i a j,v Uj °f every vertex v in S decreases, at a speed given by the coefficient ai )V . Also, 
for every cycle C included in a piece of S, we have that t(C) and 6(C) decrease, possibly 
at different speeds. We could simply increase yi until some vertex v becomes tight (that 
is, until its residual cost drops to 0). However, by doing so, it could be that t(C) ^ 6(C) 
no longer holds for some piece Q and some cycle C in Q. (For instance, this would happen 
if 6(C) decreases much faster than t(C).) We will need that t(C) ^ 6(C) remains true 
in future iterations, so that the top and bottom handles of C do not interchange (this is 



used in the proof of Lemma 5.6). For this reason, we have to keep track of 'collisions', 
as we now explain. 



This is an abuse of notation, since the support of the inequality is not always equal to S. 
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A collision occurs if, for some cycle C in a piece of S, we had t(C) < b(C) at the 
beginning of the iteration, and t{C) and b(C) become equal when increasing yi. As 
mentioned in the algorithm, we stop increasing when a collision occurs. If no vertex 
became tight during the current iteration, then the algorithm will simply keep the same 
graph S in the next iteration, but will change the coefficient of every vertex v belonging 
to a handle of C. The new coefficients are equal to 1/2 (or to 1 if C becomes the special 
cycle); in particular, t(C) and b(C) will decrease at the same speed in the future. 

Finally, let us point out that the number of consecutive iterations executed by the 
algorithm before some vertex becomes tight is bounded by the number of cycles contained 
in pieces of S, since a cycle can be involved in at most one collision. Hence, the total 
number of iterations of the algorithm is polynomial. 

5.2.5. Updating the list C (first pass). We update the collection C as follows. If S is of 
type 1, 3, or 4, we leave C unchanged. If, on the other hand, it is of type 2, we add to 
C all triples (T, B, {v, w}) that were not yet present in C, such that T is the top handle, 
B is the bottom handle and {v, w} are the ends of some cycle contained in a piece of S, 
and T has at least one internal vertex. Because S is consistent with the original list C, 
the updated list C satisfies the required properties. 

5.2.6. The insertion order. When several vertices are added to X in the same iteration, 
we pick an enumeration of the triples of C, say (Ti, B\, {v±,wi}), . . . , (Tg, Be, {vg, we}) 
having the property that all triples (Ti, Bi, {vi,Wi}) such that X contains an internal 
vertex of both T« and Bi come first, but otherwise arbitrarily. Then, we insert last all 
vertices u such that u is an internal vertex of Ti, followed by all vertices u such that u 
is an internal vertex of B\, followed by all vertices u such that u is an internal vertex of 
Ti, and so on, ending with all vertices u such that u is an internal vertex of Bg. 

5.2.7. Updating the list C (second pass). After vertices have been added to X (hence, 
deleted from H), we remove from C all triples (T, B, {v, w}) such that V(T) or V(B) has a 
non-empty intersection with the new solution X. We also remove all triples (T, B, {v, w}) 
such that one of the vertices of V(T) or V(B) will be removed when shaving G — X. 

5.3. Analysis of the algorithm. Before proceeding with the analysis of the algorithm, 
we need a lemma. 

Lemma 5.5. Consider a 2-connected graph, some of whose vertices and edges are 
marked. If no marked vertex is incident to a marked edge, then the total number of 
marked vertices and edges is at most the total number of edges. 

Proof. Consider any feasible assignment of marks to vertices and edges of a 2-connected 
graph. First, suppose that all vertices are marked and, therefore, that no edge is marked. 
Since the graph is 2-connected, the number of vertices is at most the number of edges, 
thus the result follows. 

Now, suppose that there exists an unmarked vertex. If no vertex of the graph is 
marked, we are done. Otherwise, by connectivity, there exists an edge uv such that u 
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is unmarked and v is marked, hence uv is unmarked. Unmark v and mark uv. This 
operation does not change the total number of marked elements and, by applying it 
iteratively as long as there exists a marked vertex, we eventually obtain a graph without 
any marked vertex. The result follows. □ 

Lemma 5.6. Let X be the hitting set output by the algorithm. Then 

(8) ^ a ijV ^ (l21og 3/2 n + 16) A 

vex 

for all i G {1, . . . , k}. 

Proof. First, we recall that (3i = 1 for all the inequalities in the working LP relaxation. 

Consider the ith iteration of the algorithm. In what follows, H stands for the graph 
H at the ith iteration, and S is the support graph of the ith inequality of the working 
LP. 

If S is not of type 2, then the left hand side of Q is simply the number of vertices of 
X contained in S. It follows that, if S is of type 3, then the left hand side is at most 2; 
and, if S is of type 4, then the left hand side is at most 4. 

Next, we consider the case where the type of S is 1 or 2. 

Claim 5.7. Let Q be a piece of S. Exactly one of the following four cases occurs: 

(a) X contains no internal vertex of Q, 

(b) X contains exactly one vertex of Q, and this vertex is a cutvertex of Q, 

(c) X contains exactly two vertices of Q, and they belong to opposite handles of a cycle 
ofQ, 

(d) X contains exactly one vertex per cycle of Q, each belonging to some handle of the 
corresponding cycle. 

Proof. Let Z be the set of vertices that X contained at the beginning of the ith iteration. 
(Thus, Z is the set of vertices that became tight at some iteration j with j < i.) Every 
vertex u £ V(Q) D X has a corresponding witness, namely, a diamond D u C G such 
that V(D U ) fl(IUZ) = {u}. (Such a subgraph exists because u was kept during the 
reverse delete step.) This witness D u cannot contain any vertex that was removed during 
the shaving of G — Z at the beginning of iteration i since, by definition, these vertices 
are not included in any diamond of G — Z. Hence, the diamond D u is a subgraph of 
H-(X-{u}). 

Suppose X contains some internal vertex u of Q (otherwise, Q trivially holds). Let w\ 
and u>2 be the two ends of Q. Since no internal vertex of Q has a neighbor in V{H) — V{Q) 
in H, the diamond D u must contain wi, W2, and every cutvertex of Q. Thus, X contains 
none of w\ and u>2 ■ 

If u is a cutvertex of Q, then there cannot be another internal vertex v of Q in X, for 
otherwise D v contains u. Hence, dbj) holds in this case. 

Now, assume that u is not a cutvertex of Q. By the previous observation, we may also 
assume that no other vertex in X is a cutvertex of Q. This implies that each vertex in 
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X n V(Q) — {w\, W2} belongs to a handle of a cycle in Q. Let Ai, A2 be the two handles 
of the cycle in Q containing u, with u £ V(A\). 

If A2 ^ D u , then X must contain some internal vertex v of A^- Otherwise, replacing 
the path A\ with A2 in D u gives a diamond in G — X, a contradiction. It follows that u 
and v are the only internal vertices of Q included X, since {u,v} separates w\ from W2 
in Q. Hence, Q holds. 

Finally, suppose ^2 Q D u . In this case, X contains no internal vertex of A2. Moreover, 
D u contains exactly one handle of each cycle in Q that is distinct from Ai L)A2- Consider 
such a cycle C. The set X must contain some internal vertex of the handle of C that is 
not in D u (since otherwise we could again find a diamond in G — X using that handle) . 
Furthermore, X contains at most two internal vertices of C. Otherwise, either X contains 
two vertices v, v' belonging to opposite handles of C, and {v, v'} would separate u from 
w\ or W2\ or X contains two vertices v, v' belonging to the same handle of C, and D v 
would contain v'. Therefore, Q holds. □ 



If S is of type 1, then by Claim 5.7 we can see the vertices in X n V(S) as marks on 
the pieces of S such that, if the interior of a piece is marked, then none of its ends are. 
Hence, by Lemma 5.5, \X n V(S')| is at most the number of pieces in S, which in turn is 
at most 6 log 3 / 2 n + 8. 

From now on, we assume that S is of type 2. We split the left hand side of Q into two 
parts: the vertices that are internal vertices of some piece of S, and the branch vertices. 

Claim 5.8. Consider a piece Q of S. The contribution of the internal vertices of Q to 
the left hand side of Q is at most 1 if Q does not contain the special cycle of S, and at 
most 2 if Q contains the special cycle of S. 

Proof. By our choice of coefficients for inequality ^ , the claim holds in cases @, @ and 
Q of Claim [5Jj Thus, we assume that case Q holds. First, we show that X contains 
exactly one vertex belonging to the top handle of each cycle contained in Q. 

We use the following property: For all (T, B, {v, w}) in £, the minimum residual cost 
of a vertex belonging T is less than or equal to the minimum residual cost of a vertex 
belonging to B. This holds when (T, B, {v, w}) is added to C (by the definition of top 
and bottom handles). The inequality is maintained as long as the support graph S 
is unchanged (see Section 5.2.4). Moreover, the inequality is also maintained when a 
new support graph S is chosen, because we ensure that S is always consistent with C 
(see Section 5.2.2). Consequently, the inequality is maintained through all subsequent 
iterations. 

Suppose, by contradiction, that there is a cycle C inside the piece Q, with top handle T 
and bottom handle B, such that X contains a vertex belonging to B, say u. Because case 
Q holds, (the final set) X contains no vertex belonging to T. Because of the property 
above, at the iteration in which u was added to (the evolving set) X, at least one vertex 
belonging to T was also added to X, say v! . Now, because of our particular insertion 
order, it must be the case that u was added after v! in X. Since u survived the reverse 
delete step, there is a diamond D u in G witnessing the fact that u is in (the final set) 
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X. This diamond D u does not contain v! . Hence, D u can be easily transformed into 
a diamond D u > containing v! and disjoint from X, a contradiction. It follows that X 
contains exactly one vertex belonging to the top handle of each cycle in Q. 

Now, we may assume that Q contains at least three cycles, and at least one cycle 
C such that t(C) = b(C), because otherwise the claim trivially holds. Consider such 
a cycle C, with top handle T, bottom handle B, and ends v, w. In every subsequent 
iteration such that (T, B, {v, w}) survives in £, case (Cjl]) or ((Q arises (with respect to 
the corresponding subgraph S). It follows that t(C) = b(C) holds in every subsequent 
iteration. In particular, at the iteration in which a vertex of T is added to X, a vertex of 
B is also added to X. Therefore, Q contains at most one cycle C such that t(C) = b(C). 
This is due to the fact that case Q arises and to our insertion order. 

If Q does not contain the special cycle, then the contribution of the internal vertices 
of Q to the left hand side of ([8]) is clearly at most 1/2^1. If Q contains the special 
cycle, then the contribution of the internal vertices of Q to the left hand side of Q is at 
most 1. (Recall that the special cycle is chosen among the cycles C contained in a piece 
of S and such that t(C) = 6(C), if any.) □ 

The coefficients in (18]) corresponding to the branch vertices of S are all equal to 1. 



Hence, combining Claim 5.8 and Lemma 5.5, we deduce that the left hand side of (|8|) is 



at most 12 log 3 / 2 n + 16 (since S has at most 61og 3 / 2 u + 8 pieces). □ 

Theorem 5.9. Algorithm^ is a O (log n)- approximation for the diamond hitting set 
problem. 

Proof. Letting a = 121og 3 / 2 n + 16, we have 

k k k 

^2 Cv = ^2 {^2 a ^yi) = ^(^Z ^)^ ^ ^Z a PiVi ^ a OPT, 

vGX v£X i=l ' i=l v£X i=l 

where the first equality holds because all vertices in X are tight, and the first inequality 
follows from Lemma 15.61 The result follows. □ 

5.4. Integrality gap. 

Proposition 5.10. The integrality gap of the LP defined by non-negativity and diamond 
inequalities is O(logn). 



Proof. By Theorem 5.9, we know that the integrality gap is O(logn). Now, we show that 
the integrality gap is also O(logn), using expander graphs with large girth. 

Let us first recall some standard notions from the theory of expanders. Let G be a 
d-regular graph with \G\ ^ 2. The spectral gap of G is d — A(G), where X(G) denotes 
the second largest eigenvalue of the adjacency matrix of G. The vertex-expansion h v {G) 
is defined as the minimum of 

\N(S) - S\ 
\S\ 
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over all subsets S C V(G) with \S\ ^ (Here, N(S) denotes the set of vertices of 
G having a neighbor in S.) It is well-known that the spectral gap of G can be used to 
derive a lower-bound on its vertex-expansion: 

(9) h v {G) ^ ^ (d-\(G)) ; 

see for instance the survey by Hoory, Linial, and Wigderson \10\ p. 454]. 

Lubotzky, Phillips, and Sarnak [12] proved that, for d = 6 and infinitely many values 
of n, there exists a d-regular graph G on n vertices with A (G) ^ 2y/d — 1 and girth at 
least llog^^ra (see also Margulis [IB] , and Biggs and Boshier [4]). By ([9]), the vertex- 
expansion of G satisfies 

K (G) >2d(d- 2Vd^tj = — (6 - 2^5) > 0. 

It is also known that the treewidtlj^]tw(i/) of a graph H satisfies 

tw(H) ^h v (H)---l, 

see for instance Grohe and Marx [9] Proposition 1]. It follows that 

tw (G) > £n - 1, 

where £ := ^ (6 — 2\/5~)- Since removing a vertex from a graph decreases its treewidth 
by at most 1 and forest of cacti have treewidth at most 2, this implies that the minimum 
size of a hitting set satisfies 

OPT ~Zin-3. 

On the other hand, the minimum size of a diamond in G is at least the girth, that is, at 
least I log 5 n. Thus, setting 



41og 5 ra 

yields a feasible solution of the linear relaxation. The value of the objective function for 
x* is - . Therefore, the integrality gap of the LP is at least 

OPT ^ A1 in - 3 n . 

41og 5 n • — — ^ 41og 5 n • — = S2(logra). 

on 6n 

□ 

6. A 9-APPROXIMATION ALGORITHM 
In this section, we give a primal-dual 9-approximation algorithm for the diamond 



hitting set problem. We start with a description of the algorithm in Section 6.1 This 



algorithm makes use of the sparsity inequalities. In order to describe them, we first bound 



the number of edges in a forest of cacti in Section 6.2 using this bound, in Sections |6.3 



and 6.4 we introduce the sparsity inequalities, prove their validity, and show that they 
satisfy a key inequality that we need in the analysis of the algorithm. Finally, in Section 
6.5[ we prove that our algorithm provides a 9-approximation for the diamond hitting set 



problem. 



^See Diestel [H] for a definition. 
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In the whole section, q is a global parameter of our algorithm which is set to 5. (We 
remark that the analysis below could be adapted to other values of q, but this would not 
give an approximation factor better than 9.) 

6.1. The algorithm. Our 9-approximation algorithm for the diamond hitting set prob- 
lem is very similar to the 0(logn)-approximation algorithm. The main difference is that 
we use a different set of inequalities to build the working LP relaxation. (The working 
LP relaxation and its dual are defined in Section 5.1 on page[9j) See Algorithm [3] for a 
description of the algorithm. 

Algorithm 3 A 9-approximation algorithm. 

• X <- 0; y ^ 0; i <- 0; 

• While X is not a hitting set of G = (V, E), repeat the following steps: 

— i <- % + 1 

— Let H be the graph obtained by shaving G — X 

— Find a reduced graph H of H 

— If H contains a diamond D with at most 2q— 1 edges, then let Ylvev Xv ^ 
Pi be a blended diamond inequality deduced from D as in Section 



5.2.3 



— Otherwise, in H, no two cycles of size at most q share an edge. In this case, 
let J2vev a «> Xr " ^ ^ b e * ne extended sparsity inequality with support V(H) 

— Check the inequality ^2 ve y a%,v x v ^ ft w.r.t. C, modify it if necessary, add 
it to the working LP 

— Increase yi until some vertex becomes tight, or a collision occurs 

— Update C 

— Add all tight vertices to A, in a certain order 

— Re-update C 

k ^— i 

Perform a reverse delete step on X 



The following sections are devoted to the definition of the extended sparsity inequali- 
ties. In the next paragraph we comment the last five steps in the main loop. 



First, we only modify the current inequality 



^ Pi if it is a blended 



diamond inequality. This is done as described in Section 5.2.2| Note that none of the 
modifications increases the number of pieces of the support graph S. 



Second, the tracking of collisions is performed as before (see Section 5.2.4). 

Third, C is updated similarly as before (see Section 5.2.5): if the support graph of 
the current inequality contains double pieces (in case the current inequality is an ex- 
tended sparsity inequality, the support graph is the whole graph H), we add all triples 
(T, B, {v, w}) that were not yet present in C, where T is the top handle, B is the bottom 
handle, and v, w are the ends of a cycle contained in a double piece of the support graph. 

Finally, the insertion order and the second update of C are done exactly as previously 
(see Sections 5.2.6 and 5.2.7). 
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6.2. Bounding the number of edges in a forest of cacti. The following lemma 
provides a bound on the number of edges in a forest of cacti. For i G {2, . . . ,q}, we 
denote by 7i(G) the number of cycles of length i of a graph G. 

Lemma 6.1. Let F be a forest of cacti with k components and let q^ 2. Then 

V i=2 V 

Proof Denote by 7 >g (i ? ) the number of cycles of F whose length exceeds q. We have 

i 

(10) ||F|| = |F| - k + Y,^(F) +l> q (F). 

i=2 

In the right hand side, the first two terms represent the number of edges in a spanning 
forest of F, while the last terms give the number of edges that should be added to obtain 
the forest of cacti F. 

Because every two cycles in F are edge disjoint, we have 

i 

||F||>£i 7li (F) + (<Z + l)7> ff (i0. 

i=2 



Combining this with (10), we get 



q 

(11) l> q (F) < - (\F\ -k-J2(i- IH(F) 

5 i=2 



From (10) and ( |11[ ), we finally infer 

3 



F\\ < |F|-fc+^ 7j (F)+^-(|F|-fc-^(z-l) 7 ,(F)) < ^±l(\F\-k)+J2^J±l^ F) . 

□ 



i=2 ' 8=2 ' i=2 ^ 



6.3. The sparsity inequalities. We define the Joad of a vertex v in a graph G as 

* G («) :=d G («)-^A i7 i(G», 

i=2 

where, for i £ {2, . . . , q}, 7i(G, u) denotes the number of cycles of length i incident to v 
in G and 

_ q-i + 1 
4 • [i/2\ q ■ 

For q = 5, we have 

A2 = — , At = — , A4 = - , and A5 = — . 
5 5 ' 5 ' 5 10 

Lemma 6.2. Let X be a hitting set of a graph G where no two cycles of length at most 

q share an edge. Then, 

(12) £ ( feW - *±i) > noil - ?±i|oi -yj^i±i 7i( G) + «±i. 



We call Inequality (12) a sparsity inequality. 
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Proof of Lemma \6.S\ For i S {2, . . . , q} and j G {0, . . . we denote by £| the number 
of cycles of G that have length i and exactly j vertices in X. 

Letting ||X|| and |<5(AT)| respectively denote the number of edges of G with both ends 
in X and the number of edges of G having an end in X and the other in V(G) — X, we 
have 

E*g(«) = 2\\X\\ + \S(X)\-J2J2j\ i 4 

v&X i=2 j=l 

= \\X\\ + \\G\\-\\G-X\\-j2i2^^i 

i=2 j=l 

> 11*11 + - £±I(| G - X| - 1) - £ q -^±l -±£j A, el, 

q i=2 q i=2 j=l 



where the last inequality follows from Lemma |6.1| applied to the forest of cacti G — X 
(notice that ji(G - X) = £?). 

Because no two cycles of length at most q share an edge and, in a cycle of length i, 
each subset of size j induces a subgraph that contains at least 2j — i edges, we have 

t=2 i=l+L|j 

Thus, we obtain 

E^)>E E (2j-o^+iiGii-^(iG-xi-i)-^i^^-EE^^^- 

v&X i=2 j=l+LiJ *= 2 *=2 j=l 

We leave it to the reader to check that, in the right hand side of the last inequality, the 
total coefficient of £| is at least — q ~ l q +1 , for all i € {2, ... , q} and j G {0, . . . , i}. Hence, 

E w > noil - ^101 + *tVi + ^ -E^^g). 



Inequality (12) follows. □ 



6.4. The extended sparsity inequalities. Consider a shaved graph H and denote by 
H a reduced graph of H. Suppose that, in H, no two cycles of length at most q share 
an edge. Thus, the graph H can be uniquely decomposed into simple or double pieces 
corresponding to edges or pairs of parallel edges in H. Here, the pieces of H are defined 
as follows: let v and w be two adjacent vertices of H, and let J denote the subgraph of 
H induced by {v, w}. The primitive subgraph of J in H, say J, is a piece of H with ends 
v and w. The vertices of H are of two types: the branch vertices are those that survive 
in H, and the other vertices are internal to some piece of H. 

Consider a double piece Q of H (if any) and a cycle C contained in Q. As before, 
denote by t{C) (resp. 6(C)) the minimum residual cost of a vertex in the top handle 
(resp. bottom handle) of C. Also, we choose a cycle of Q (if any) and declare it to be 
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special. If possible, the special cycle is chosen among the cycles C contained in Q with 
t(C) = b(C). (So every double piece of H has a special cycle.) 
The extended sparsity inequality for H reads 

(13) a v x v ^ fi, 

veV(H) 



where 



and 



^s(v) — ^— — if v is a branch vertex, 
H q 

1 if v is an internal vertex of a simple piece, 

2 if v is an internal vertex of a double piece and does not belong to any handle, 

if v belongs to the top handle of a cycle C with t(C) < b(C), 

2 if v belongs to the bottom handle of a cycle C with t(C) < b(C), 

1 if v belongs to a handle of a cycle C with t(C) = b(C), or C is special, 

+ 1 , ~ , + 1 . ~. 9 + 1 



By convention, the support graph of the extended sparsity inequality ( 13 ) is defined to 
be H. 

Lemma 6.3. Let H be a graph and let H be a reduced graph of H such that no two 

n hen Ira 

a v ^ P 



cycles of length at most q share an edge. Then Inequality ( 13 ) is valid, that is, 



whenever X is a hitting set of H. 



Proof. Let Y denote the set of branch vertices that are included in X. So Y = V(H)nX. 
Then Y is not necessarily a hitting set of H. Indeed, H — Y is a forest of cacti F to which 
a certain number of extra edges are added: the extra edges are those corresponding to 
the vertices of X that are internal to some piece, that is, vertices of X — Y . By our choice 
of coefficients, 

a v >\\H-Y\\-\\F\\. 

v&X-Y 

In other words, the left hand side is at least the number of extra edges. 



The rest of the proof closely follows the proof of Lemma 6.2 This time, all computa- 
tions are made within the reduced graph. Precisely, K denotes the number of cycles of 
H that have length i and exactly j vertices in Y, \ \Y\\ denotes the number of edges of H 
with both ends in Y and |<5(Y)| denotes the number of edges of H having one end in Y 
and the other in V(H) — Y. Then, we have 

EW+ E a - = 2||y|| + | ( 5(y)|-X;E-?' A ^' + ll^- y ll-ll i? ll 

VEY veX-Y i=2 j=l 

= \\H\\ + \\Y\\-\\F\\-j2Y,i X ^i- 

i=2 3=1 
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By using Lemma 6.1 to bound ||-F|| and the inequality & ji(F), we obtain 



Ew+ E «> > \m + \\Y\\- q ^(\F\-i)-± q -^^F)-±± J x l e i 

veY veX-Y q i=2 y i=2 j=l 

" -I- 1 ~ ^g-z + l 



> \\h\\ + urn - ^(iJffi -m-i)-E e? - EEi 



i=2 ^ i=2 j=l 



After performing the same steps as in the proof of Lemma 6.2 in the graph H this 
time, we find 

h%W+ V a„ > -H] + y + >^ 7i(#)- 

^— ' z — ' q q q ^-^ q 

veY vex-Y H H H i=2 4 



This proves the validity of the extended sparsity Inequality (13). □ 



6.5. Analysis of the algorithm. We now prove a key inequality that will be used in 
the analysis of the algorithm. 

Lemma 6.4. Let H be a shaved graph and let H be a reduced graph of H . Suppose that, 
in H, every diamond has at least 2q = 10 edges. Then, 



vex 

for every minimal hitting set X of H . 

Proof. Let Y := V(H) D X. We note that no two cycles of length at most 5 in H have 
an edge in common, since H has no diamond with at most 9 edges. 

We have to prove that 
(14) 

+ 1\ . „ fn^n g+l.s, s^q-i + l ^ 4 + 1 



v&Y 

We claim that 



v£Y 9 veX-Y ' i=2 



a v = \\H-Y\\-\\F\\, 

v&X-Y 

where the sum is taken over all vertices that are included in X and that are internal to 
some piece. Indeed, since X is minimal, there are four ways in which X can intersect 



internal vertices of a piece Q (see Claim 5.7 above): 

• X contains no internal vertex of Q, 

• X contains exactly one vertex of Q, and this vertex is a cutvertex of Q, 

• X contains exactly two vertices of Q, and they belong to opposite handles of a 
cycle of Q, 

• X contains exactly one vertex per cycle of Q, each belonging to some handle of 
the corresponding cycle. 
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In the three first cases, the choice for the coefficients ensures that the equality holds. 



In the fourth case, using the same arguments as in Claim 5.8 above, we prove that X 
contains one vertex in the top handle of each cycle of Q. The left hand side can be 
rewritten as: 



E(w-^) + E = m\\ + \s(Y)\-±±jx^- q -±^\Y\ 

v& q vdX—Y i=2 j=l q 

+\\H-Y\\ - \\F\\ 
< 2||#||-| W |-^^ J A 4 ^-^m 

i=2 j=l q 

-2IIFII - (\\H-Y\\ - \\F\\). 



Let k denote the number of components of the forest of cacti F. Since \ \F\ \ = \F\ — k + 
£?= 2 7*(^) +7> q (F) and \F\ = \H\ - \Y\, we have 



v&Y q veX-Y i=2 j=l q 

q 

-2{\H\ — \Y\ — k + E li(F) + l> q {F)] 

i=2 

-(\\H-Y\\-\\E(F)\\) 

q i q 

^ 2||tf||-2|tf|-^^jA i £-2^ 7i (F)-2 7>9 (F) 

i=2 j=l i=2 

-\6(Y)\ -(\\H-Y\\- \\F\\) + —\Y\ + 2k. 



Now, let Vi (i = {2, . . . ,q}) be defined as Vi := for i ^ 3 and v% := |. Notice that 
< jXi for all i € {2, ... , <?} and j G {!,..., £}. Also, v { < £^n^ for all £ € {2, ... , <?}. 
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We rewrite the last inequality as 



E(W-^)+ E a " ^ 2||if||-| J ff|-^^jA l ^-2^ 7j (F)-2 7>(? (F) 



q I 



veX-Y 



i=2 j=l 



i=2 



i=2 



i=2 



9-1, 



-\5{Y)\-{\\H-Y\\-\\F\\) + *—\Y\+2k 



q % 



^ 2\\H\ | -\H\-J2 * T»(#) - £ £0' A * " **) $ 

i=2 i=2 j=l 

-(2 - n) £ 7i (F) - 2 7>9 (F) + ^ - 7i (F)) 



i=2 



i=2 
9-1, 



-(||ff-y||-||F||) + 2-_|y| + 2A: 



i=2 



i=2 



9-1, 



-|S(y)|-(||tf-Y||-||F||) + ^— \Y\ + 2k. 



Therefore, to prove Inequality (14), it suffices to show the following: 

q 



6||ff|| + (2 -8 
+1*001 - 



q + 1 
Q 

g-1 
9 



j=2 



i/i 7 i(lf) + 8 



+ 1 



|y| + ||^_y||_|| F ||_2fc-^^- 7i (F)) > 0. 



i=2 



We actually prove a slightly stronger inequality: 

q 



611^11+2-8 



q + 1 



q-i + l 



i=2 



q-1 



\Y\ + \\H-Y\\-\\F\\-2k-^2^- 7l (F)) > 0. 



We proceed in two steps. We first show that 

i 



(15) 



6||^||+2-8- 



9 + 1 



i^i -E 



i=2 



i=2 



i + 1 



Vi)ji(H) > 0, 



then we show that 

(16) 1*001 + \\H-Y\\- \\F\\ > ^l±\Y\ + 2k + Y t ~ 



i=2 
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Let us start with Inequality (15). By multiplying by grW) we rewrite it as: 

ili-H-i-t(-^i-?)^)>^ 

The above inequality has the following simple interpretation: the average load of a vertex 
should be at least the right hand side, where the load of vertex v is redefined as 

W ■= d S {v) -I • ± (8 • i^tl _ li{ H, v). 

i=2 q 

Recalling that q = 5, Vi = for i ^ 3 and v§ = |, we get that the right hand side is 
equal to || and the load is as follows: 

1 5 - 4+1 \ 4 (^-^-^W.»> 



3V 4-5 / ' v ' y 3 V 5-5 
= dg(v) - — j 2 (H, v) - ■— j 3 (H, v)- — J4(H, v) - — 75(5", v) 

As is reduced, the minimum load of a vertex is 3 — = || (think of a vertex incident 
to three edges, two of which determine a cycle of length 3) . As a consequence, the average 
load of a vertex is at least the right hand side, and Inequality (15) follows. 



Let us now prove Inequality (16). Since q = 5, Vi = for i ^ 3 and u$ = |, the 
inequality reads \S(Y)\ + \\H - Y\\ - \\F\\ ^ ^\Y\ + 2k + §(£§ - 73(F)). We will prove 
the following slightly stronger inequality: 

(17) |*Q0| + \\H - Y\\ - \\F\\ > \Y\ + 2k + - 73(F)). 

To prove it, we use arguments that are similar to those used in [5]. First observe that 
the quantities \ \H — Y\ \ — \ \F\ \ and ^3 — 73(F) respectively correspond to the number of 
extra edges and the number of extra triangles contained in H — Y. Furthermore, each 
extra edge can generate at most one extra triangle, since H has no diamond with at most 
9 edges. 

We build a bipartite graph J as follows. Start with H, and contract each of the k 
components of H — Y into a single vertex (as usual, we keep the newly created parallel 
edges, if any, and we remove the loops). Then, remove all edges having both endpoints 
in Y. 

It follows from the fact that A" is a minimal hitting set of H that, for each vertex 
v E Y, there exists a diamond D v in H that is vertex-disjoint from Y — {v} and edge- 
disjoint from E(H — Y) — F(F). Moreover, for each extra edge e G E{H — Y) — F(F), 
there exists a diamond D e in H that is vertex-disjoint from Y and edge-disjoint from 
E(H — Y) — F(F) — {e}. We call these diamonds a witness for v and e, respectively. 

In particular, for every v £ Y, we can choose a component K of H — Y such that there 
are at least two edges between v and K in J; we call the pair (v, K) a primary pair. We 
remove from J one edge between v and K for each primary pair (v, K). Noticed that we 
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removed exactly \Y\ edges from J; thus, to prove Inequality (17), it is enough to show 
that 

(18) \\J\\ + \\H-Y\\-\\F\\^2k + ^-j 3 (F)). 

In the remainder of this proof, our aim is to show that, for each component K of 
H — Y, the number of edges of J incident to K plus the number of extra edges in K is 
at least 2 plus 3/5 times the number of extra triangles in K, that is: 

(19) dj(K) + \\K\\-\\KnF\\ ^2 + % 3 (K)- ri (KnF)). 

5 



Clearly, Inequality (19) implies Inequality (18). 

First, we recall that, since H is reduced, every vertex of H has at least three neighbors. 
Consider a component K of H — Y. Let ij = r](K) := ||if || — ||if Hi 7 !! denote the number 
of extra edges in K, and r = t(K) := 73 (if) — 73 (K n F) denote the number of extra 
triangles in K. With these notations, Inequality (19) becomes 

(20) dj(K) + r,>2 + K. 

Note that 77 ^ t, since no two extra triangles have an edge in common. Therefore, we 
may assume that one of the two following cases occurs (otherwise ( 20 ) holds) : 

(i) dj(K) = and 77 < 4, or 

(ii) dj(K) = 1 and 7/ < 2. 

Both cases can be handled using similar arguments, hence we treat them in parallel 
and only highlight the differences when necessary. 

In case (i), if is a component of H, and hence every vertex of K has at least three 
distinct neighbors in K. In case (ii), there are vertices in V(K) having a neighbor in Y 
in the graph H; these vertices are said to be special. Note that K belongs to at most one 
primary pair (v,K), because otherwise we would have dj{K) ^ 2. It follows that there 
are at most two special vertices in K. Moreover, in K, every non-special vertex has at 
least three distinct neighbors, while every special vertex has at least two of them. 

Let L := K D F. Each extra edge in K has a witness in H, and this witness avoids all 
the other extra edges and the vertices in Y, thus L is a component of F, and hence L is 
a cactus. 

First, we prove that every cycle in L has at most 7 vertices. Arguing by contradiction, 
assume C is a cycle of L with |C| ^ 8. This cycle is a block of L, and each vertex of 
C either has degree 2 in L, or is a cutvertex of L. Let t be the number of vertices of C 
having degree 2 in L. Now, for each cutvertex v of L included in C, there is at least one 
endblock B v of L such that v separates B v from C in L. Observe that either \B V \ =2, 
and thus one of its vertices has only one neighbor in L, or \B V \ 3 and B v is a simple 
cycle, and thus at least two of its vertices have degree 2 in L. This directly gives the 
following lower bound on rj\ 



t/2 + (\C\-t) in case (i), 

t/2 + (|C| -t) - 1 in case (ii). 
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(The —1 in case (ii) comes from the existence of special vertices in K.) In case (i), since 
77 ^ 4, we must have 77 = 4, |C| = t = 8, and L = C. However, by taking the union of C 
with an extra edge of K we obtain a diamond in K having 9 edges, a contradiction. In 
case (ii), we directly get a contradiction, because 77 ^ 2 and t/2 + (|C| — i) — 1 ^ 3. (The 
last inequality is derived using t ^ \C\ and |C| ^ 8.) 

Consider an extra triangle in K. If there is only one extra edge e in that triangle, then 
the unique cycle C in D e — e is a cycle of L which has at least one edge in common with 
the triangle. (Recall that D e denotes the witness of e in K.) As we have seen, we must 
have |C| ^ 7. However, this implies ||-D e || ^ 9, contradicting the fact that every diamond 
in H has at least 10 edges. Thus, every extra triangle contains at least two extra edges. 
Since the extra triangles are edge disjoint, this implies 

(21) 77 ^ 2r. 



In case (ii), Inequality (21) allows us to easily show that (20) holds: First, suppose 
r ^ 1. Then, by (21), we have 

77 ^ 2r ^ 1 + f t, 
5 

as desired. Now, assume r = 0. Here, we only need to show 77 ^ 1. Suppose the contrary, 
that is, 77 = 0. Then K = L, and hence K is a cactus. Recall that K has at most two 
special vertices, and that each of these vertices has at least two neighbors in K. Thus, if 
some endblock B of K is isomorphic to K2 or to a cycle consisting of two parallel edges, 
then some vertex of B has only one neighbor in K, a contradiction. This implies that all 
the endblocks of K are simple cycles. Using this observation, it is easily seen that 77 ^ 1 
if there are more than one endblock in K. Thus, K consists of a single block, and hence 
if is a simple cycle. However, since \K\ ^ 3, there is a non-special vertex in K with 
degree 2, a contradiction. Therefore, we must have 77 ^ 1, which concludes case (ii). 

Now, consider case (i). Here, it is easily seen that 77 ^ 2: First, \L\ = \K\ 4, since 
every vertex of K has at least three distinct neighbors in K. Thus, if L has only one 
endblock, then L must be a simple cycle on at least 4 vertices, implying 7/^2. Similarly, 
if L has at least two endblocks, then by considering two such endblocks we deduce again 
77 ^ 2. This implies that Inequality (20) holds if r = 0. Hence, we may assume r ^ 1. 

If 77 ^ 3, then (21) gives 

3 3 7 1 

2 H — r 2 H 77 = 77 + 2 77 = 77 ^77. 

5 10 ' 10 ' 10 ' 

Thus, it remains to handle the case where 77 = 2 and r = 1. We will show that this case 

cannot happen, because it leads to a contradiction. 

Let ei,e2,f denote the three edges forming the unique extra triangle in K, with e\ 

and e2 being the two extra edges of K. These two edges are incident to a common vertex, 

which we denote v. Observe that this vertex must be contained in some endblock B v of 

L (otherwise, 77 ^ 3). 

Let Bf be the block of L including the edge /. Suppose Bf is a cycle. This cycle has 
length at most 7. If v G V(Bf), then each extra edge gives a diamond with at most 8 
edges in K. Similarly, if v ^ V(Bf), then using the two extra edges we obtain a diamond 
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in K with at most 9 edges. Thus, in both cases we get a contradiction. This implies 
Bf = K2- In particular, Bf ^ B v , since otherwise we would have \Bf\ ^ 3. 

Now, Bf cannot be an endblock of L, as otherwise some vertex of Bf would have 
degree only 2 in K. This implies that there is an endblock of L distinct from B v that 
contains a vertex having at most two neighbors in K, a contradiction. This concludes 
the proof. □ 

Lemma 6.5. For the minimal hitting set X output by Algorithm^ we have 
for all i E {1, . . . , k}. 

Proof. If the ith inequality of the working LP relaxation is an extended sparsity inequal- 
ity, the result follows from the previous lemma. Thus, we may assume that the ith 
inequality is deduced from a diamond D (thus ft = 1). Hence, D has at most 2q — 1 = 9 
edges. Let S denote the support graph of the ith inequality. If S is of type 1, then it has 
at most 9 pieces. If it is of type 2, it has at most 8 pieces. If it is of type 3 or 4, the left 
hand side is at most two. The result then follows from the arguments used in the proof 
of Lemma 15.61 □ 



Our main result directly follows from Lemma 6.5 The proof is identical to the proof 
of Theorem 15.91 and hence is omitted. 



Theorem 6.6. Algorithm^ is a 9- approximation for the diamond hitting set problem. 
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